<template>
	<view class="list">
		<view class="msearch">
			<u-search v-model="param.title" :animation="true" action-text="取消" placeholder="输入搜索内容" shape="round" @search="search" @clear="clear"></u-search>
		</view>
		<view class="r_item" v-for="(item, index) in list" :key="index" @click="detail(item)">
			<image :src="ip + item.showPictures" mode="aspectFill" class="pic"></image>
			<view class="con">
				<view class="title omit">{{ item.title }}</view>
				<view class="ms">
					<text class="icon">&#xec86;</text>
					<text class="ll">{{ item.browseNum }}</text>
				</view>
				<view class="lx" @click.stop="lx(item)">
					<text class="icon">&#xe603;</text>
					<text>景区路线</text>
				</view>
			</view>
			<view class="clear"></view>
		</view>
		<view class="loading"><u-loadmore :status="loadMore ? 'loading' : 'nomore'" /></view>
	</view>
</template>

<script>
export default {
	data() {
		return {
			ip: this.$http.urls.ip,
			list: [],
			param: { pageNum: 1, pageSize: 10, serviceInfo: 2, title: '',orderByColumn: 'createTime', isAsc: 'desc' },
			loadMore: true
		};
	},
	onLoad() {
		this.getData();
	},
	methods: {
		//获取数据
		getData() {
			this.$http.request({
				url: this.$http.urls.getPageContent,
				data: this.param,
				loading: 'false',
				success: res => {
					this.loadMore = res.data.pages > this.param.pageNum ? true : false;
					res.data.rows.forEach(item => {
						this.list.push(item);
					});
				}
			});
		},
		//路线
		lx(item) {
			uni.navigateTo({ url: '/pages/travel/route?id=' + item.contentId });
		},
		//详情
		detail(item) {
			uni.navigateTo({ url: '/pages/travel/detail?id=' + item.contentId });
		},
		//点击键盘搜索按钮触发
		search() {
			this.refresh();
		},
		//清空搜索内容
		clear() {
			this.refresh();
		},
		//刷新数据
		refresh() {
			this.loadMore = true;
			this.param.pageNum = 1;
			this.list = [];
			this.getData();
		}
	},
	//下拉刷新
	onPullDownRefresh() {
		setTimeout(() => {
			uni.stopPullDownRefresh();
			this.refresh();
		}, 1000);
	},
	//上拉加载
	onReachBottom() {
		if (this.loadMore) {
			this.param.pageNum++;
			this.getData();
		}
	}
};
</script>

<style lang="scss">
.list {
	padding: 10px 17px 70px 17px;
}
</style>
